{% extends 'users/_user.html' %}
{% load i18n %}
{% load bootstrap3 %}
{% block user_template_title %}{% trans "Update user" %}{% endblock %}
{% block password %}
    {% if object.can_update_password %}
    {% bootstrap_field form.password layout="horizontal" %}
    {#  密码popover  #}
    <div id="container">
        <div class="popover fade bottom in" role="tooltip" id="popover777" style=" display: none; width:260px;">
            <div class="arrow" style="left: 50%;"></div>
            <h3 class="popover-title" style="display: none;"></h3>
            <h4>{% trans 'Your password must satisfy' %}</h4><div id="id_password_rules" style="color: #908a8a; margin-left:20px; font-size:15px;"></div>
            <h4 style="margin-top: 10px;">{% trans 'Password strength' %}</h4><div id="id_progress"></div>
            <div class="popover-content"></div>
        </div>
    </div>
    {% else %}
    <div class="form-group">
        <label class="col-sm-2 control-label">{% trans 'Password' %}</label>
        <div class="col-sm-8 controls" style="margin-top: 8px;" id="password_help_text">
            {% trans 'User auth from {}, go there change password' %}
        </div>
    </div>
    {% endif %}
    {% if object.can_update_ssh_key %}
    {% bootstrap_field form.public_key layout="horizontal" %}
    {% else %}
        <div class="form-group">
            <label class="col-sm-2 control-label">{% trans 'ssh public key' %}</label>
            <div class="col-sm-8 controls" style="margin-top: 8px;" id="ssh_key_help_text">
                {% trans 'User auth from {}, ssh key login is not supported' %}
            </div>
        </div>
    {% endif %}
{% endblock %}

{% block custom_foot_js %}
    {{ block.super }}
<script>
function passwordCheck() {
    if ($('#id_password').length != 1) {
        return
    }
    var el = $('#id_password_rules'),
        idPassword = $('#id_password'),
        idPopover = $('#popover777'),
        container = $('#container'),
        progress = $('#id_progress'),
        password_check_rules = {{ password_check_rules|safe }},
        minLength = 6,
        top = idPassword.offset().top - $('.navbar').outerHeight(true) - $('.page-heading').outerHeight(true) - 10 + 34,
        left = 377,
        i18n_fallback = {
            "veryWeak": "{% trans 'Very weak' %}",
            "weak": "{% trans 'Weak' %}",
            "normal": "{% trans 'Normal' %}",
            "medium": "{% trans 'Medium' %}",
            "strong": "{% trans 'Strong' %}",
            "veryStrong": "{% trans 'Very strong' %}"
        };

    $.each(password_check_rules, function (idx, rules) {
        if(rules.key === 'id_security_password_min_length'){
            minLength = rules.value
        }
    });

    // 初始化popover
    initPopover(container, progress, idPassword, el, password_check_rules, i18n_fallback);

    // 监听事件
    idPassword.on('focus', function () {
        idPopover.css('top', top);
        idPopover.css('left', left);
        idPopover.css('display', 'block');
    });
    idPassword.on('blur', function () {
        idPopover.css('display', 'none');
    });
    idPassword.on('keyup', function(){
        var password = idPassword.val();
        checkPasswordRules(password, minLength);
    });
}
$(document).ready(function(){
    passwordCheck();

    var origin_password_text = $("#password_help_text").text();
    var new_password_text = origin_password_text.replace('{}', "{{ object.source_display }}");
    $("#password_help_text").html(new_password_text);

    var origin_ssh_key_text = $("#ssh_key_help_text").text();
    var new_ssh_key_text = origin_ssh_key_text.replace('{}', "{{ object.source_display }}");
    $("#ssh_key_help_text").html(new_ssh_key_text)

})
.on("submit", "form", function (evt) {
    evt.preventDefault();
    var the_url = '{% url 'api-users:user-detail' pk=object.id %}';
    var redirect_to = '{% url "users:user-list" %}';
    var method = "PUT";
    var form = $("form");
    var data = form.serializeObject();
    objectAttrsIsList(data, ['groups']);
    objectAttrsIsDatetime(data,['date_expired']);
    var props = {
        url: the_url,
        data: data,
        method: method,
        form: form,
        redirect_to: redirect_to
     };
    formSubmit(props);
})
</script>
{% endblock %}
